class Solution {
public:
    int maxSubArray(vector<int>& nums) {
        const int m = nums.size();
        int dp[m];
        dp[0] = max(0, nums[0]);
        
        int ret = nums[0];
        for(int i = 1; i < m; ++i)
        {
            dp[i] = max(dp[i - 1] + nums[i], nums[i]);
            ret = max(ret, dp[i]);
        }

        return ret;
    }
};
